#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>

//定义队列结构，底层结构是链表
typedef int QDataType;
typedef struct QueueNode
{
	QDataType data;
	struct QueueNode* next;
}QueueNode;


//队列的队头和队尾指针
typedef struct Queue
{
	QueueNode* phead;
	QueueNode* ptail;
	int size;//保存队列有效数据个数
}Queue;


void QueueInit(Queue* pq);//初始化队列

void QueuePush(Queue* pq, QDataType x);// ⼊队列，队尾

void QueuePop(Queue* pq);// 出队列，队头

bool QueueEmpty(Queue* pq);//队列判空

QDataType QueueFront(Queue* pq);//取队头数据

QDataType QueueBack(Queue* pq);//取队尾数据

int QueueSize(Queue* pq);//队列有效元素个数

void QueueDestroy(Queue* pq);//销毁队列
